<template>
	<div class="ratings" ref="ratings">
		<div class="ratings-content">
			<div class="overview">
				<div class="overview-left">
					<h1 class="score">{{seller.score}}</h1>
					<div class="title">综合评价</div>
					<div class="rank">高于周边商家{{seller.rankRate}}</div>
				</div>
				<div class="overview-right">
					<div class="score-wrapper">
						<span class="title">服务态度</span>
						<star :size="36" :score="seller.serviceScore"></star>
						<span class="score">{{seller.serviceScore}}</span>
					</div>
					<div class="score-wrapper">
						<span class="title">商品评分</span>
						<star :size="36" :score="seller.foodScore"></star>
						<span class="score">{{seller.foodScore}}</span>
					</div>
					<div class="delivery-wrapper">
						<span class="title">送达时间</span>
						<span class="delivery">{{seller.deliveryTime}}分钟</span>
					</div>
				</div>
			</div>
			<split></split>
			<ratingselect :select-type="selectType" :only-content="onlyContent" :desc="desc" :ratings="ratings" @typeselect="_typeselect" @togglecontent="_togglecontent"></ratingselect>
			<div class="rating-wrapper">
				<ul>
					<li class="rating-item" v-for="rating in ratings" v-show="needShow(rating.rateType, rating.text)">
						<div class="avatar">
							<img :src="rating.avatar" width="28" height="28">
						</div>
						<div class="content">
							<h1 class="name">{{rating.username}}</h1>
							<div class="time">{{rating.rateTime | formatDate}}</div>
							<div class="star-wrapper">
								<star :size="24" :score="rating.score"></star>
								<span class="delivery" v-if="rating.deliveryTime">{{rating.deliveryTime}}</span>
							</div>
							<p class="text">{{rating.text}}</p>
							<div class="recommend" v-if="rating.recommend && rating.recommend.length">
								<span class="icon-thumb_up"></span>
								<span class="item" v-for="item in rating.recommend">{{item}}</span>
							</div>
						</div>
					</li>
				</ul>
			</div>
		</div>
	</div>
</template>

<script type="text/ecmascript-6">
	import BScroll from 'better-scroll';
	import star from 'components/star/star.vue';
	import split from 'components/split/split.vue';
	import ratingselect from 'components/ratingselect/ratingselect.vue';
	import {formatDate} from '../../common/js/date.js';

	const ALL = 2;
	const ERR_OK = 0;

	export default {
		props: {
			seller: {
				type: Object
			}
		},
		data() {
			return {
				ratings: [],
				selectType: ALL,
				onlyContent: false,
				desc: {
					all: '全部',
					positive: '推荐',
					negative: '吐槽'
				}
			};
		},
		created() {
			this.$http.get('/api/ratings').then((response) => {
				response = response.body;
				if (response.errno === ERR_OK) {
					this.ratings = response.data;
					this.$nextTick(() => {
						this.scroll = new BScroll(this.$refs.ratings, {
							click: true
						});
					});
				}
			});
		},
		filters: {
			formatDate(time) {
				let date = new Date(time);
				return formatDate(date, 'yyyy-MM-dd hh:mm');
			}
		},
		methods: {
			needShow(type, text) {
				if (this.onlyContent && !text) {
					return false;
				}
				if (this.selectType === ALL) {
					return true;
				} else {
					return type === this.selectType;
				}
			},
			_typeselect(type) {
				this.selectType = type;
				this.$nextTick(() => {
					this.scroll.refresh();
				});
			},
			_togglecontent(onlyContent) {
				this.onlyContent = onlyContent;
				this.$nextTick(() => {
					this.scroll.refresh();
				});
			}
		},
		components: {
			star,
			split,
			ratingselect
		}
	};
</script>

<style lang="stylus" rel="stylesheet/stylus">
	@import '../../common/stylus/mixin.styl'
	.ratings
		position absolute
		top 174px
		bottom 0px
		left 0px
		width 100%
		overflow hidden
		.overview
			display flex
			padding 18px 0
			.overview-left
				flex 0 0 137px
				padding 6px 0
				width 137px
				border-right 1px solid rgba(7, 17, 27, .1)
				text-align center
				@media only screen and (max-width 320px)
					flex 0 0 100px
					width 100px
				.score
					margin 0 0 6px
					line-height 28px
					font-size 24px
					color rgb(255, 153, 0)
				.title
					margin-bottom 8px
					line-height 12px
					font-size 12px
					color rgb(7, 17, 27)
				.rank
					line-height 10px
					font-size 10px
					color rgb(147, 153, 159)
			.overview-right
				flex 1
				padding 6px 0 6px 24px
				@media only screen and (max-width 320px)
					padding 6px 0 6px 6px
				.score-wrapper
					margin-bottom 8px
					font-size 0
					.title
						display inline-block
						vertical-align top
						font-size 12px
						line-height 18px
						color rgb(7, 17, 27)
					.star
						display inline-block
						vertical-align top
						margin 0 12px
					.score
						display inline-block
						vertical-align top
						font-size 12px
						line-height 18px
						color rgb(255, 153, 0)
				.delivery-wrapper
					font-size 0
					.title
						font-size 12px
						line-height 18px
						color rgb(7, 17, 27)
					.delivery
						margin-left 12px
						font-size 12px
						color rgb(147, 153, 159)
		.rating-wrapper
			padding 0 18px
			.rating-item
				display flex
				padding 18px 0
				border-1px(rgba(7, 17, 27, .1))
				.avatar
					flex 0 0 28px
					width 28px
					margin-right 12px
					img
						border-radius 50%
				.content
					position relative
					flex 1
					.name
						margin 0 0 4px
						line-height 12px
						font-size 14px
						color rgb(7, 17, 27)
					.star-wrapper
						margin-bottom 6px
						font-size 0
						.star
							display inline-block
							margin-right 6px
							vertical-align top
						.delivery
							display inline-block
							vertical-align top
							font-size 10px
							line-height 12px
							color rgb(147, 153, 159)
					.text
						margin 0 0 8px
						line-height 18px
						color rgb(7, 17, 27)
						font-size 12px
					.recommend
						line-height 16px
						font-size 0px
						.icon-thumb_up, .item
							display inline-block
							margin 0 8px 4px 0
							font-size 10px
						.icon-thumb_up
							color rgb(0, 160, 220)
						.item
							padding 0 6px
							border 1px solid rgba(7, 17, 27, .1)
							border-radius 1px
							color rgb(147, 153, 159)
							background-color #FFF
					.time
						position absolute
						top 0px
						right 0px
						line-height 12px
						font-size 10px
						color rgb(147, 153, 159)
</style>